import { RouteRecordRaw } from 'vue-router';

/**
 * 建议：路由 path 路径与文件夹名称相同，找文件可浏览器地址找，方便定位文件位置
 *
 * 路由meta对象参数说明
 * meta: {
 *      title:          菜单栏及 tagsView 栏、菜单搜索名称（国际化）
 *      isLink：        是否超链接菜单，开启外链条件，`1、link: 链接地址不为空 2、isIframe:false`
 *      isHide：        是否隐藏此路由
 *      isKeepAlive：   是否缓存组件状态
 *      isAffix：       是否固定在 tagsView 栏上
 *      isIframe：      是否内嵌窗口，开启条件，`1、isIframe:true 2、isLink：链接地址不为空`
 *      roles：         当前路由权限标识，取角色管理。控制路由显示、隐藏。超级管理员：admin 普通角色：common
 *      icon：          菜单、tagsView 图标，阿里：加 `smom-icon xxx`，fontawesome：加 `fa xxx`
 * }
 */

// 扩展 RouteMeta 接口
declare module 'vue-router' {
	interface RouteMeta {
		title?: string;
		link?: string;
		isHide?: boolean;
		isKeepAlive?: boolean;
		isAffix?: boolean;
		isIframe?: boolean;
		roles?: string[];
		icon?: string;
	}
}

/**
 * 定义动态路由
 * 前端添加路由，请在顶级节点的 `children 数组` 里添加
 * @description 未开启 isRequestRoutes 为 true 时使用（前端控制路由），开启时第一个顶级 children 的路由将被替换成接口请求回来的路由数据
 * @returns 返回路由菜单数据
 */
export const dynamicRoutes: Array<RouteRecordRaw> = [
	{
		path: '/',
		name: '/',
		component: () => import('@/layout/index.vue'),
		redirect: '/home',
		meta: {
			isKeepAlive: true
		},
		children: [
			{
				path: '/home',
				name: 'home',
				component: () => import('@/views/home/index.vue'),
				meta: {
					title: 'message.router.publishPlatform',
					isLink: '',
					isHide: false,
					isKeepAlive: true,
					isAffix: true,
					isIframe: false,
					icon: 'smom-icon smom-icon-fabu'
				},
				redirect: "",
				children: []
			},
			{
				path: '/smom',
				name: 'smom',
				component: () => import("@/layout/routerView/parent.vue"),
				redirect: "/smom/project",
				meta: {
					title: 'message.router.smom',
					isLink: '',
					isHide: false,
					isKeepAlive: true,
					isAffix: false,
					isIframe: false,
					icon: 'smom-icon smom-icon-smom'
				},
				children: [
					{
						path: '/smom/project',
						name: 'smomProject',
						component: () => import('@/views/project/index.vue'),
						meta: {
							title: 'message.router.projectManage',
							isLink: '',
							isHide: false,
							isKeepAlive: true,
							isAffix: false,
							isIframe: false,
							icon: 'smom-icon smom-icon-xiangmuguanli'
						},
					},
					{
						path: '/smom/appconfig',
						name: 'smomAppconfig',
						component: () => import('@/views/appconfig/index.vue'),
						meta: {
							title: 'message.router.appconfig',
							isLink: '',
							isHide: false,
							isKeepAlive: true,
							isAffix: false,
							isIframe: false,
							icon: 'smom-icon smom-icon-appconfig'
						},
					},
					{
						path: '/smom/papersPublish',
						name: 'smomPapersPublish',
						component: () => import('@/views/papersPublish/index.vue'),
						meta: {
							title: 'message.router.papersPublish',
							isLink: '',
							isHide: false,
							isKeepAlive: true,
							isAffix: false,
							isIframe: false,
							icon: 'smom-icon smom-icon-shoudongfabu'
						},
					}
				]
			},
			{
				path: '/server',
				name: 'server',
				component: () => import('@/views/servers/index.vue'),
				meta: {
					title: 'message.router.server',
					isLink: '',
					isHide: false,
					isKeepAlive: true,
					isAffix: false,
					isIframe: false,
					icon: 'smom-icon smom-icon-fuwuqi'
				},
				redirect: "",
				children: []
			},
			{
				path: '/tfs',
				name: 'teamFoundationServer',
				component: () => import('@/views/teamFoundationServer/index.vue'),
				meta: {
					title: 'message.router.tfs',
					isLink: '',
					isHide: false,
					isKeepAlive: true,
					isAffix: false,
					isIframe: false,
					icon: 'smom-icon smom-icon-tfs'
				},
				redirect: "",
				children: []
			},
			{
				path: '/backups',
				name: 'backups',
				component: () => import('@/views/backups/index.vue'),
				meta: {
					title: 'message.router.backups',
					isLink: '',
					isHide: false,
					isKeepAlive: true,
					isAffix: false,
					isIframe: false,
					icon: 'smom-icon smom-icon-beifenjilu'
				},
				redirect: "",
				children: []
			},
			{
				path: '/sshInstall',
				name: 'sshInstall',
				component: () => import('@/views/sshInstall/index.vue'),
				meta: {
					title: 'message.router.sshInstall',
					isLink: '',
					isHide: true,
					isKeepAlive: true,
					isAffix: false,
					isIframe: false,
					icon: 'smom-icon smom-icon-fuwuqi'
				},
				redirect: "",
				children: []
			}			
		]
	}
];

/**
 * 定义404、401界面
 * @link 参考：https://next.router.vuejs.org/zh/guide/essentials/history-mode.html#netlify
 */
export const notFoundAndNoPower = [
	{
		path: '/:path(.*)*',
		name: 'notFound',
		component: () => import('@/views/error/404.vue'),
		meta: {
			title: 'message.staticRoutes.notFound',
			isHide: true
		}
	},
	{
		path: '/401',
		name: 'noPower',
		component: () => import('@/views/error/401.vue'),
		meta: {
			title: 'message.staticRoutes.noPower',
			isHide: true
		}
	}
];

/**
 * 定义静态路由（默认路由）
 * 此路由不要动，前端添加路由的话，请在 `dynamicRoutes 数组` 中添加
 * @description 前端控制直接改 dynamicRoutes 中的路由，后端控制不需要修改，请求接口路由数据时，会覆盖 dynamicRoutes 第一个顶级 children 的内容（全屏，不包含 layout 中的路由出口）
 * @returns 返回路由菜单数据
 */
export const staticRoutes: Array<RouteRecordRaw> = [
	/**
	 * 提示：写在这里的为全屏界面，不建议写在这里
	 * 请写在 `dynamicRoutes` 路由数组中
	 *
	{
		path: '/login',
		name: 'login',
		component: () => import('@/views/login/index.vue'),
		meta: {
			title: '登录',
		},
	}
	*/
];
